Current File : /var/www/prestashop/modules/ps_accounts/src/Http/Client/Guzzle/GuzzleClient.php
<?php
/**
 * Copyright since 2007 PrestaShop SA and Contributors
 * PrestaShop is an International Registered Trademark & Property of PrestaShop SA
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Academic Free License version 3.0
 * that is bundled with this package in the file LICENSE.md.
 * It is also available through the world-wide-web at this URL:
 * https://opensource.org/licenses/AFL-3.0
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@prestashop.com so we can send you a copy immediately.
 *
 * @author    PrestaShop SA and Contributors <contact@prestashop.com>
 * @copyright Since 2007 PrestaShop SA and Contributors
 * @license   https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0
 */

namespace PrestaShop\Module\PsAccounts\Http\Client\Guzzle;

use PrestaShop\Module\PsAccounts\Factory\CircuitBreakerFactory;
use PrestaShop\Module\PsAccounts\Http\Client\CircuitBreaker\CircuitBreaker;
use PrestaShop\Module\PsAccounts\Http\Client\ClientInterface;
use PrestaShop\Module\PsAccounts\Vendor\GuzzleHttp\Client;

abstract class GuzzleClient implements ClientInterface
{
    /**
     * @var Client
     */
    protected $client;

    /**
     * @var string
     */
    protected $route;

    /**
     * @var int
     */
    protected $timeout = 10;

    /**
     * @var bool
     */
    protected $catchExceptions = false;

    /**
     * @var CircuitBreaker
     */
    protected $circuitBreaker;

    /**
     * @param array $options
     *
     * @throws \Exception
     */
    public function __construct($options)
    {
        $this->circuitBreaker = CircuitBreakerFactory::create(
            isset($options['name']) ? $options['name'] : static::class
        );
        unset($options['name']);
    }

    /**
     * @param mixed $response
     *
     * @return array
     */
    public function handleResponse($response)
    {
        $responseContents = $this->getResponseJson($response);

        return [
            'status' => $this->responseIsSuccessful($responseContents, $response->getStatusCode()),
            'httpCode' => $response->getStatusCode(),
            'body' => $responseContents,
        ];
    }

    /**
     * @param mixed $response
     *
     * @return mixed
     */
    public function getResponseJson($response)
    {
        return json_decode($response->getBody()->getContents(), true);
    }

    /**
     * @param array $options payload
     *
     * @return array return response or false if no response
     */
    public function post(array $options = [])
    {
        return $this->circuitBreaker->call(function () use ($options) {
            $response = $this->getClient()->post($this->getRoute(), $options);
            $response = $this->handleResponse($response);
            $this->logResponseError($response, $options);

            return $response;
        });
    }

    /**
     * @param array $options payload
     *
     * @return array return response or false if no response
     */
    public function patch(array $options = [])
    {
        return $this->circuitBreaker->call(function () use ($options) {
            $response = $this->getClient()->patch($this->getRoute(), $options);
            $response = $this->handleResponse($response);
            $this->logResponseError($response, $options);

            return $response;
        });
    }

    /**
     * @param array $options payload
     *
     * @return array return response or false if no response
     */
    public function get(array $options = [])
    {
        return $this->circuitBreaker->call(function () use ($options) {
            $response = $this->getClient()->get($this->getRoute(), $options);
            $response = $this->handleResponse($response);
            $this->logResponseError($response, $options);

            return $response;
        });
    }

    /**
     * @param array $options payload
     *
     * @return array return response array
     */
    public function delete(array $options = [])
    {
        return $this->circuitBreaker->call(function () use ($options) {
            $response = $this->getClient()->delete($this->getRoute(), $options);
            $response = $this->handleResponse($response);
            $this->logResponseError($response, $options);

            return $response;
        });
    }

    /**
     * @param array $responseContents
     * @param int $httpStatusCode
     *
     * @return bool
     */
    public function responseIsSuccessful($responseContents, $httpStatusCode)
    {
        return '2' === substr((string) $httpStatusCode, 0, 1);
    }

    /**
     * Getter for client.
     *
     * @return Client
     */
    public function getClient()
    {
        return $this->client;
    }

    /**
     * @param Client $client
     *
     * @return void
     */
    public function setClient(Client $client)
    {
        $this->client = $client;
    }

    /**
     * @return string
     */
    public function getRoute()
    {
        return $this->route;
    }

    /**
     * @param string $route
     *
     * @return void
     */
    public function setRoute($route)
    {
        $this->route = $route;
    }

    /**
     * @param array $response
     * @param array $options
     *
     * @return void
     */
    private function logResponseError(array $response, array $options)
    {
        // If response is not successful only
        if (\Configuration::get('PS_ACCOUNTS_DEBUG_LOGS_ENABLED') && !$response['status']) {
            /** @var \Ps_accounts $module */
            $module = \Module::getInstanceByName('ps_accounts');
            try {
                $logger = $module->getLogger();
                $logger->debug('route ' . $this->getRoute());
                $logger->debug('options ' . var_export($options, true));
                $logger->debug('response ' . var_export($response, true));
            } catch (\Exception $e) {
            }
        }
    }
}
Page Not Found
Parece que el enlace que apuntaba aquí no sirve. ¿Quieres probar con una búsqueda?
¡Hola!